package mo.tags.count;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class L229 {

    public List<Integer> majorityElement(int[] nums) {
        int n = nums.length;
        int condition = n / 3;
        Map<Integer, Integer> map = new HashMap<>();
        for (int num : nums) {
            map.put(num, map.getOrDefault(num, 0)+1);
        }
        List<Integer> res = new ArrayList<>();
        for (Map.Entry<Integer, Integer> entry : map.entrySet()) {
            if (entry.getValue() > condition) {
                res.add(entry.getKey());
            }
        }
        return res;
    }

}
